package parser;

import org.w3c.dom.*;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;

/**
 * @author 石小俊
 * @date 2023年11月01日 14:47
 */
public class PrintDOMParser {

    public static void main(String[] args) {
        DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
        try {
            DocumentBuilder builder = factory.newDocumentBuilder();
            Document document = builder.parse(PrintDOMParser.class.getClassLoader().getResourceAsStream("students.xml"));
            Element root = document.getDocumentElement();
            print(root);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    public static void print(Element root){
        // 打印开始标签
        System.out.print("<"+root.getTagName());
        // 打印标签属性
        NamedNodeMap attributes = root.getAttributes();
        for(int i = 0; i < attributes.getLength();i++){
            System.out.print(" "+attributes.item(i));
        }
        System.out.print(">");

        // 打印标签体
        NodeList nodes = root.getChildNodes();
        for(int i = 0; i < nodes.getLength(); i++){
            Node node = nodes.item(i);

            // 不同节点处理方式也不同
            if(node.getNodeType() == Node.ELEMENT_NODE){
                // 如果是元素节点,通过递归继续解析
                Element element = (Element) node;
                print(element);
            }

            if(node.getNodeType() == Node.TEXT_NODE){
                // 如果是文本节点,则直接打印文本内容
                System.out.print(node.getTextContent());
            }
        }

        // 打印结束标签
        System.out.print("</"+root.getTagName()+">");
    }

}
